# Use Vivado to build an Embedded System

#### Introduction

This lab guides you through the process of using Vivado to create a simple ARM Cortex-A9 based processor design targeting the ZedBoard or Zybo board. Where the instructions refer to both boards, choose the board you are using. You will use Vivado to create the hardware system and SDK (Software Development Kit) to create an example application to verify the hardware functionality.

## **Objectives**

After completing this lab, you will be able to:

- Create a Vivado project for a Zynq system
- Use the IP Integrator to create a hardware system
- Use SDK to create a standard memory test project
- Run the test application on the board

#### **Procedure**

This lab is separated into steps that consist of general overview statements that provide information on the detailed instructions that follow. Follow these detailed instructions to progress through the lab.

This lab comprises 5 primary steps: You will create a top-level project using Vivado, create the processor system using the Vivado IP Integrator, generate the top-level HDL and export the design to SDK, create a Memory Test application in SDK, and finally, test in hardware.

# **Design Description**

The purpose of the lab exercises is to walk you through a complete hardware and software processor system design. Each lab will build upon the previous lab. The following diagram represents the completed design (**Figure 1**).



Figure 1. Completed Design

In this lab, you will use IP Integrator to create a processing system based design consisting of the following (**Figure 2**):

- ARM Cortex A9 core (PS)
- UART for serial communication
- DDR3 controller for external DDR3 SDRAM memory



Figure 2. Processor Design of this Lab

# **General Flow for this Lab**



In the instructions below;

{ sources} refers to: C:\Xilinx\_trn\Zynq\_base\ \_sources

{ labs } refers to : C:\Xilinx\_trn\Zynq\_base\

# **Create a Vivado Project**

Step 1

- 1-1. Launch Vivado and create an empty project targeting the ZedBoard or the Zybo, using the VHDL language.
- 1-1-1. Open Vivado by selecting Start > All Programs > Xilinx Design Tools WEB 2018.3> Vivado 2018.3
- **1-1-2.** Click **Create New Project** to start the wizard. You will see the *Create a New Vivado Project* dialog box. Click **Next**.
- **1-1-3.** Click the Browse button of the *Project Location* field of the **New Project** form, browse to **{labs}**, and click **Select**.
- **1-1-4.** Enter **lab1** in the *Project Name* field. Make sure that the *Create Project Subdirectory* box is checked. Click **Next**.



Figure 3. Project Name Entry

- **1-1-5.** In the *Project Type* form select **RTL Project**, and click **Next**
- **1-1-6.** In the *Add Sources* form, select **Verilog** as the *Target language* and **Mixed** as the *Simulator language*



Figure 4. Add sources to new project

- 1-1-7. Click Next two more times to skip Add Constraints
- 1-1-8. In the Default Part form select Boards and then select ZedBoard and click Next.



Figure 5. Boards and Parts Selection

1-1-9. Check the *Project Summary* and click **Finish** to create an empty Vivado project.

# **Creating the System Using the IP Integrator**

Step 2

- 2-1. Use the IP Integrator to create a new Block Design, add the ZYNQ processing system block, and import the provided xml file for the board.
- 2-1-1. In the Flow Navigator, click Create Block Design under IP Integrator



Figure 6. Create IP Integrator Block Diagram

**2-1-2.** Enter **system** for the design name and click **OK** 



Figure 7. Create New Block Diagram

- **2-1-3.** IP from the catalog can be added in different ways:
- 2-1-3.1. Click the Add IP icon in the block diagram side bar,
- 2-1-3.2. OR press Ctrl + I,
- 2-1-3.3. OR click the Add IP icon in the empty Diagram workspace,
- 2-1-3.4. OR right-click anywhere in the Diagram workspace and select Add IP.



Figure 8. Add IP to Block Diagram

**2-1-4.** Once the IP Catalog is open, type "z" into the Search bar, find and double click on **ZYNQ7 Processing System** entry, or click on the entry and hit the Enter key to add it to the design.



Figure 9. Add Zynq block to the design

Notice the message at the top of the Diagram window that Designer Assistance available.



Figure 10. Run block automation

- 2-1-5. Click Run Block Automation.
- **2-1-6.** In the *Run Block Automation* window, select **/processing\_system7\_0**, leave the default settings, including *Apply Board Preset* checked, and click **OK**



Figure 11. Block Automation settings

**2-1-7.** Click on the C (Regenerate Layout) button and see the following block diagram.



Figure 12. Zynq Block with DDR and Fixed IO ports

Once Block Automation has been complete, notice that ports have been automatically added for the DDR and Fixed IO, and some additional ports are now visible.

**2-1-8.** Double-click on the added block (ZYNQ) to open its *Customization* window.

Notice now the *Customization* window shows selected peripherals (with tick marks). This is the default configuration for the board applied by the block automation.



Figure 13. Imported peripherals settings

#### 2-2. Configure the processing block with just UART 1 peripheral enabled.

2-2-1. A block diagram of the Zyng shows various configurable blocks of the Processing System.

At this stage, the designer can click on various configurable blocks (highlighted in green) and change the system configuration.

Only the UART is required for this lab, so all other peripherals will be deselected.

- **2-2-2.** Click on one of the peripherals (in green) in the *IOP Peripherals* block, or select the *MIO Configuration* tab on the left to open the configuration form
- **2-2-3.** Expand I/O peripherals if necessary, and ensure all the following I/O peripherals are deselected, i.e. remove: Expand **Memory Interfaces** to deselect *Quad SPI Flash*

Expand I/O Peripherals to deselect ENET 0

to deselect USB 0

to deselect SD 0

expand GPIO to deselect GPIO MIO

Expand Application Processor Unit to disable Timer 0.



Figure 14. Selecting only UART 1

- **2-2-4.** Select the **PS-PL Configuration** tab on the left.
- **2-2-5.** Expand AXI Non Secure Enablement > GP Master AXI interface and deselect **M AXI GP0** interface.
- **2-2-6.** Expand *General > Enable Clock Resets* and deselect the **FCLK\_RESET0\_N** option.

- **2-2-7.** Select the *Clock Configuration* tab on the left. Expand the *PL Fabric Clocks* and deselect the **FCLK\_CLK0** option and click **OK.**
- **2-2-8.** Click on the C (Regenerate Layout) button and see the following block diagram.



Figure 15. Updated Zynq Block

**2-2-9.** Click on the (Validate Design) button and make sure that there are no errors.

### **Generate Top-Level and Export to SDK**

Step 3

- 3-1. Generate IP Integrator Outputs, the top-level HDL, and start SDK by exporting the hardware.
- **3-1-1.** In the **Sources** panel, right-click on *system.bd*, and select **Generate Output Products** ... and click **Generate** to generate the Implementation, Simulation and Synthesis files for the design (You can also click on **Generate Block Design** in the Flow Navigator pane to do the same)
- **3-1-2.** Right-click again on *system.bd*, and select **Create HDL Wrapper**... to generate the top-level Verilog model. Leave the *Let Vivado manager wrapper and auto-update* option selected, and click **OK**

The system\_wrapper.v file will be created and added to the project.



Figure 16. The HDL Wrapper file generated and added to the project

**3-1-3.** Notice that the Verilog file is already *Set As the Top* module in the design

Double-click on the file to see the content in the Auxiliary pane.

**3-1-4.** Select **File > Export > Export hardware**. (Save the project if prompted)



Figure 17. Exporting hardware

Since we do not have any hardware in Programmable Logic (PL) there is no bitstream to generate, hence the **Include bitstream** option is not necessary at this time.

3-1-4.1. Click OK

#### 3-1-5. Select File > Launch SDK leaving the default settings, and click OK



Figure 18. Launch SDK

- **3-1-6.** If only the Welcome panel is visible, close or minimize this panel to view the *Project Explorer* and *Preview* panel.
- **3-1-7.** SDK should now be open.

A Hardware platform project should have been automatically created, and the system\_wrapper\_hw\_platform\_0 folder should exist in the Project Explorer panel.



Figure 19. SDK C/C++ development view

The **system.hdf** file (Hardware Description File) for the Hardware platform should open in the preview pane. Double click system.hdf to open it if it is not.

Basic information about the hardware configuration of the project can be found in the .hdf file, along with the Address maps for the PS systems, and driver information. The .hdf file is used in the software environment to determine the peripherals available in the system, and their location in the address map.

# **Generate Memory TestApp in SDK**

Step 4

- 4-1. Generate memory test application using one of the standard projects template.
- 4-1-1. In SDK, select File > New > Application Project



Figure 20. Create new SDK application project

- **4-1-2.** Name the project **mem\_test**, (Note that this application will run on ps7\_cortexa9\_0 i.e. core 0 of the two processor cores available.)
- **4-1-3.** In the *Board Support Package* section, leave *Create New* selected and leave the default name *mem\_test\_bsp*.
- 4-1-4. Click Next.
- 4-1-5. Select Memory Tests from the Available Templates window, and click Finish.



Figure 21. Creating Memory Tests C Project

The **mem\_test** project and the board support project **mem\_test\_bsp** will be created and will be visible in the Project Explorer window of SDK, and the two projects will be automatically built. You can monitor the progress in the Console panel.

- **4-1-6.** Expand folders in the Project Explorer view, and observe that there are three projects
- system\_wrapper\_hw\_platform\_0. The hw\_platform includes the ps7\_init function which initializes the PS as part of the first stage bootloader.
- mem\_test\_bsp. The mem\_test\_bsp is the board support package
- mem\_test. The mem\_test project is the application that we will use to verify the functionality of the design.



Figure 22. The Project Explore view

**4-1-7.** Open the **memorytest.c** file in the mem\_test project (under *src*), and examine the contents. This file calls the functions to test the memory.

Test in Hardware Step 5

#### 5-1. Establish the serial communication using SDK's Terminal tab.

- **5-1-1.** ZedBoard: Make sure that two micro-usb cables are used between the PC and the PROG and the UART connectors of the board and that the board is placed in the JTAG mode (MIO6 and MIO2 jumpers are in the GND position).
- **5-1-2.** Turn ON the power
- 5-1-3. Select the \*\*Terminal\* tab. If it is not visible then select Window > Show view > Terminal.
- **5-1-4.** Click on connect icon.
- **5-1-5.** Select appropriate COM port (depends on your computer), and configure it with the parameters as shown.



Figure 23. SDK Terminal Settings

You can find the COM port from the Windows Device Manager, in this case, COM4:



Figure 24. COM ports in Windows control panel

- 5-2. Run the mem\_test application and verify the functionality.
- **5-2-1.** In SDK, select the **mem\_test** project in *Project Explorer*, right-click and select **Run As > Launch on Hardware (GDB)** to download the application, and will execute ps7\_init, and then execute mem\_test.elf (user application).



Figure 25. Launch Application

**5-2-2.** You should see the following output on the *Terminal* tab.

```
NOTE: This application runs with D-Cache disabled. As a result, cacheline request
s will not be generated
Testing memory region: ps7 ddr 0
   Memory Controller: ps7 ddr
         Base Address: 0x00100000
                 Size: 0x1ff00000 bytes
          32-bit test: PASSED!
          16-bit test: PASSED!
          8-bit test: PASSED!
Testing memory region: ps7 ram 1
   Memory Controller: ps7_ram
         Base Address: 0xffff0000
                 Size: 0x0000fe00 bytes
          32-bit test: PASSED!
          16-bit test: PASSED!
           8-bit test: PASSED!
--Memory Test Application Complete--
```

Figure 26. SDK Terminal Output

**5-2-3.** Close SDK and Vivado by selecting **File > Exit** in each program.

#### Conclusion

Vivado and the IP Integrator allow base embedded processor systems and applications to be generated very quickly. After the system has been defined, the hardware can be exported and SDK can be invoked from Vivado. Software development is done in SDK which provides several application templates including memory tests. You verified the operation of the hardware by downloading a test application, executing on the processor, and observing the output in the serial terminal window.